package fanjingzhu.check.dao;

import java.util.List;
import publics.model.Application;

public interface ApplicationDao {

	/**
	 * 保存一个企业的贷款申请表到数据库
	 * @param application 公司实体        
	 * @return 主键id
	 */
	public Integer save(Application application);
	
	/**
	 * 根据id删除企业贷款申请表
	 * @param applicationId
	 * @return
	 */
	public boolean deleteById(Integer applicationId);
	
	/**
	 * 根据实例删除企业贷款申请表
	 * @param application 贷款申请表实例
	 * @return
	 */
	public boolean delete(Application application);
	

	/**
	 * 修改贷款申请表
	 * @param application  公司实体 
	 * @return  boolean 成功 true ，失败 false
	 */
	public boolean update(Application application);

	/**
	 * 据贷款申请表id查找 
	 * @param 公司表id
     * @return id对应的公司表
	 */
	public Application findById(Integer id);
	
	/**
	 * 查询所有贷款申请表
	 * @param hql 要查询的hql语句
	 * @param offset 起始条目偏移量（offset == （页码-1）*pageSize ，ajax传过来的start = offset ）
	 * @param pageSize  查询每页的条目数
	 * @return 查询的所有企业
	 */
	public List<Application> findByPage(final String  hql, final int offset, final int pageSize);

	
	/**
	 * 分页查找的贷款申请表的总记录
	 * @param sql 查询语句
	 * @return 记录总数
	 */
	public int findByCount(String sql);
	/**
	 * 根据sql条件进行查找（主要为了按照state来找）
	 * @param query
	 * @return
	 */
	public List<Application> findByQuery(String query);
	
	/**
	 * 通过企业id 查找申请表
	 * @param entId  企业id
	 * @return   找到的 所有申请表(结果按 申请表 id 降序排列)
	 */
	public List<Application> findByEntId(Integer entId);
	
}
